Word recognizing apparatus for dynamically generating feature amount of word and method thereof

ABSTRACT

A word recognizing apparatus extracts the feature amount from a given image, and dynamically composes the feature amount of a candidate word to be recognized which is registered in a word list, using feature amounts of characters registered in an individual character dictionary. Then, the apparatus collates the composed feature amount of the word with the feature amount extracted from the image, calculates the degree of similarity between the two feature amounts, and outputs a recognition result.

BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention

[0002] The present invention relates to a pattern recognizing method in which a pattern string is collectively recognized, and more particularly to a word recognizing apparatus for collectively recognizing a word and the method thereof.

[0003] 2. Description of the Related Art

[0004] Conventional methods of pattern recognition are classified into the following three groups from the viewpoint of character division and extraction.

[0005] In the first method, a word is divided and extracted using its image features in units of characters, and the divided and extracted characters are individually recognized. Main image features include the blank and pitch between characters, a histogram obtained by projecting an image in the direction perpendicular to a character string, the circumscribed rectangle of the joint component of pixels, the unevenness of the upper and lower contours of an image, etc.

[0006] In the second method, a plurality of division and extraction hypotheses are developed, and each hypothesis is verified using the result of character recognition. In one case, the extraction and division hypothesis can be obtained by moving an observation window in the image, and in the other case, the extraction and division hypothesis can be obtained by using the image features described above. For verification a dynamic programming (DP) is often used to obtain complete consistency.

[0007] However, since in the case of a handwritten character string which is written with no restriction, pitch between characters is not uniform and the image features of parts to be extracted are diverse, the method has a problem in that characters cannot be divided and extracted satisfactorily. In the case where characters are searched using the observation window also, characters cannot be handled by a fixed window since pitch is not uniform. However, if the size of the window is made variable, the process time increases greatly.

[0008] Furthermore, since the image features of a part to be divided and extracted are peculiar to character types, such as kanji, hiragana, alphabets and numeric characters, the same problem also occurs in the case of a word composed of printed characters when touched characters are separated, if these different types of characters are mixed.

[0009] In the third method, a word itself is recognized without dividing the word in units of characters and extracting the characters. According to this method, although the difficult problem of character division and extraction can be avoided, this method has a problem that the number of candidates to be registered in a recognition dictionary in advance increases rapidly compared with the case where each individual character is recognized. Actually, since the size of the dictionary is restricted to a practical level due to memory capacity, only a limited number of words can be registered, and thereby its usage is restricted.

SUMMARY OF THE INVENTION

[0010] It is an object of the present invention to provide a word recognizing apparatus for collectively recognizing a word with as little restriction as possible on the recognizable scope of words.

[0011] In the first mode of the present invention, a word recognizing apparatus comprises a list unit, a dictionary unit, a generating unit and a collating unit. The list unit stores a list of one or more words, and the dictionary unit stores the feature amount of characters. The generating unit generates the feature amount of a word stored in the list unit using the feature amounts of characters stored in the dictionary unit. The collating unit collates the generated feature amount of a word with the feature amount of a recognition target, and outputs its recognition result.

[0012] In the list stored in the list unit, candidate words to be recognized as a result are registered, and in the dictionary unit, the feature amounts of individual characters composing these words are registered. The generating unit refers to the list in the list unit, extracts the feature amount of each of the characters composing a word from the dictionary unit, and composes the feature amount of the word. The collating unit collates the feature amount composed by the generating unit with the feature amount of the recognition target contained in an input image, calculates the degree of similarity between the two feature amounts, etc., and outputs it as its recognition result.

[0013] In the second mode of the present invention, a word recognizing apparatus comprises a generating unit and a collating unit. The generating unit dynamically generates the feature amount of a word using the feature amounts of its characters. The collating unit collates the generated feature amount of the word with the feature amount of a recognition target, and outputs its recognition result.

[0014] In the third mode of the present invention, a recognizing apparatus comprises a generating unit and a collating unit. The generating unit dynamically generates the feature amount of a pattern string using the feature amounts of patterns. The collating unit collates the generated feature amount of the pattern string with the feature amount of a recognition target, and outputs its recognition result.

BREIF DESCRIPTION OF THE DRAWINGS

[0015]FIG. 1 shows the principle of a word recognizing apparatus of the present invention.

[0016]FIG. 2 shows the configuration of a word recognizing apparatus.

[0017]FIG. 3 is a flowchart showing the process of a feature extracting unit.

[0018]FIG. 4 shows the relationship between the positions of contour points and direction codes.

[0019]FIG. 5 shows 16 direction codes.

[0020]FIG. 6 shows how to determine 16 direction codes.

[0021]FIG. 7 shows a one-dimensional Gaussian distribution type filter.

[0022]FIG. 8 shows a basic mesh division and the center position of a mask.

[0023]FIG. 9 shows a direction code histogram series.

[0024]FIG. 10 shows the composition of the feature amount.

[0025]FIG. 11 is a flowchart showing the processes of both a feature collating unit and a feature generating unit.

[0026]FIG. 12 shows DP matching.

[0027]FIG. 13 shows a DP matching process.

[0028]FIG. 14 shows an example of an image.

[0029]FIG. 15 shows an example of a feature collation process.

[0030]FIG. 16 shows the configuration of an information processing device.

[0031]FIG. 17 shows storage media.

DESCRIPTION OF THE PREFERRED EMBODIMENT

[0032] The detailed preferred embodiment of the present invention is described below with reference to the drawings.

[0033]FIG. 1 shows the principle of a word recognizing apparatus of the present invention. A word recognizing apparatus shown in FIG. 1 comprises a list unit 1, a dictionary unit 2, a generating unit 3 and a collating unit 4.

[0034] The list unit 1 stores a list of one or more words, and the dictionary unit 2 stores feature amounts of characters. The generating unit 3 generates the feature amount of a word stored in the list unit 1 using the feature amounts of characters stored in the dictionary unit 2. The collating unit 4 collates the generated feature amount of the word with the feature amount of a recognition target, and outputs its recognition result.

[0035] In the list stored in the list unit 1, candidate words to be recognized as a result are registered, and in the dictionary unit 2, the feature amounts of individual characters composing these words are registered. The generating unit 3 refers to the list in the list unit 1, extracts the feature amount of each of the characters composing a word from the dictionary unit 2, and composes the feature amount of the word. The collating unit 4 collates the feature amount composed by the generating unit 3 with the feature amount of the recognition target contained in an input image, calculates the degree of similarity, etc., between the two feature amounts, and outputs it as its recognition result.

[0036] In this way, by dynamically generating the feature amounts of only candidate words in the course of a recognizing process, and not by preparing in advance a word dictionary in which there are the feature amounts of many words, the amount of memory to be used can be reduced. Since there is no need to register the feature amounts of words in the list, many words can be registered in the list, and thereby the feature amounts of these words can be generated on occasion. For this reason, the scope of words can not be restricted as in a conventional word dictionary.

[0037] For example, the list unit 1, the dictionary unit 2, the generating unit 3 and the collating unit 4 shown in FIG. 1 correspond to a word list 14, an individual character dictionary 15, a feature generating unit 13 and a feature collating unit 12, respectively, shown in FIG. 2 and described later.

[0038] In the following descriptions, a case where character strings contained in an image to be recognized are horizontal is assumed in order to simplify the descriptions. Characters are horizontally connected, and words are also written horizontally. However, the present invention can also be applied to a case where character strings are vertical and characters are vertically connected.

[0039] The word recognizing apparatus in this embodiment dynamically generates a word dictionary from a dictionary of individual characters, and collectively recognizes a word. A key point in realizing such a word recognizing apparatus is to determine the feature amounts and a method of composing them in such a way that the feature amount obtained from a word image may match the composed feature amount of each of the characters composing the word.

[0040] In the individual character dictionary, the feature amounts of individual characters are registered, and by mixing feature amounts of individual characters, the feature amount of a corresponding word is generated. It is assumed here that a word X (=“AB”) is composed of characters A and B, the images of characters A and B and the word X are images a, b and x, respectively, and the feature amounts obtained from those images are α, β and χ, respectively.

[0041] At this time, in order to generate the feature amount of a word from the feature amounts of its individual characters, a composition operation f has to be defined between two feature amounts, and χ=f(α, β) has to hold true. That such a condition holds true is assumed to mean that operation f is commutative for the ordinary composition of an image.

[0042] The feature amount of characters and words conventionally used is gradated in order to avoid the shift and deformation of characters. In the gradating process, an image is divided by a predetermined number of meshes, and a direction code histogram in each of the small obtained areas is weighted and added to that of a small area surrounding it. Since by this gradating process, information relating to the small surrounding areas is introduced into a small area, the shift of characters and deformation of their styles can be absorbed.

[0043] However, if such a gradating process is applied to a word, the direction code histogram of one character is weighted and added to that of the other on the boundary of two characters, and a commutative composition operation f is not easily found.

[0044] Under these circumstances, in this embodiment a conventional gradating process using Gaussian distribution, etc., is applied to the vertical direction which is perpendicular to the connecting direction of characters, but no gradation is applied to the horizontal direction which is the connecting direction of characters. In this way, the feature amount is generated.

[0045] If the feature amount is applied to a word written horizontally, the direction code histogram of one character is not weighted and added to that of the other on the boundary between two characters, and a commutative composition operation f is easily obtained by simply arranging two feature amounts of characters. However, in this situation the shift and deformation of characters are not taken into consideration. Therefore, when a distance between an image and a candidate to be recognized is calculated, its recognition accuracy is arranged to be improved using DP matching.

[0046] The conventional feature amount of a character can be obtained by dividing an image by a predetermined number of meshes. If this mesh-division is applied to a word with a plurality of characters, the more characters are contained in the word, the larger the meshes become. For this reason, if the resolution of the meshes becomes relatively low, the recognition accuracy will be affected.

[0047] Therefore, in this embodiment the number of meshes is changed according to the length of a word. Since in the case of a word horizontally written the vertical length of an image is fixed even if the number of characters increases, the vertical length of the image is divided by a predetermined number and the obtained quotient is designated as the size of a basic mesh. Mesh-division is performed horizontally and vertically based on the size. In this case, the number of horizontal meshes varies depending on the horizontal length of the image. However, since DP matching is used in the calculation of the distance, uncertainty due to the change in the number of meshes is absorbed.

[0048] The description on the feature amount of a word vertically written can be obtained by replacing the word “horizontal” with the word “vertical” in the above description on the feature amount of a word written horizontally.

[0049]FIG. 2 shows the configuration of the word recognizing apparatus of this embodiment. The word recognizing apparatus shown in FIG. 2 comprises a feature extracting unit 11, a feature collating unit 12, a feature generating unit 13, a word list 14 and an individual character dictionary 15.

[0050] The feature extracting unit 11 extracts the feature amount from a given image, and the feature generating unit 13 composes the feature amount of a candidate word to be recognized, and is stored in the word list 14. The feature collating unit 12 collates the feature amount extracted by the feature extracting unit 11 with the feature amount of a word generated by the feature generating unit 13 using the feature amounts of words generated by the feature generating unit 13 as a word dictionary, and outputs a word that has the closest feature amount as the first candidate of the recognition result.

[0051] At this time, although it is desirable for the word list 14 to contain the word indicated by an image to be recognized, the process often become complicated if there are too many words. Therefore, several word lists 14 are prepared in advance, the feature generating unit 13 estimates a word list 14 with a high possibility of containing a word to be recognized according to the previous recognition result, and uses it.

[0052] For example, when the image of an address in a letter written in Japanese is processed, it is judged that there is a high possibility that a name of a city, town or village will appear if the immediately preceding recognition result was a name of a prefecture such as “Tokyo” or “Hokkaido”, and thus a word list 14 containing names of cities, towns and villages is selected, and the feature amount of a word is composed.

[0053] Next, the process of the feature extracting unit 11 is described with reference to FIGS. 3 to 9. FIG. 3 is a flowchart showing the process of the feature extracting unit 11. This is a process obtained by adding a new part to a process described in a paper, Shinji Tsuruoka et al., “Handwritten “KANJI” and “HIRAGANA” Character Recognition Using Weighted Direction Index Histogram Method,” Journal of the Institute of Electronic Information and Communication (D),Vol. J70-D, No. 7, pp. 1390-1397, July 1987.

[0054] The feature extracting unit 11 first inputs an image to be recognized (step S1), and generates a direction code vector field (step S2). Then, the unit 11 performs the basic mesh-division of the image and generates a direction code histogram vector field (step S3), and performs a vertical gradating conversion using a one-dimensional Gaussian distribution function (step S4). Then, the unit 11 compresses the vector of the direction code histogram vector field (step S5), extracts the feature amount, and terminates the process.

[0055] In step S2, the feature extracting unit 11 first performs the eight-connection contour trace of the input image, and designates the obtained contour point series result as {Ci}. Here, Ci corresponds to a pixel on the contour of a pattern contained in the image. Then, the unit 11 determines a direction code di with eight directions on the contour point Ci, based on the position of the contour point Ci+1 subsequent to it.

[0056]FIG. 4 shows the relationship between the position of contour point Ci+1 with contour point Ci as a center and a direction code. For example, Ci+1 is positioned on the right of Ci (di=1), Ci+1 is positioned on the upper right of Ci (di=3), and Ci+1 is positioned above Ci (di=5).

[0057] Then, by averaging a direction code di at Ci and a direction code di−1 at a contour point Ci−1 immediately preceding Ci, a direction code Di with 16 directions at Ci, as shown in FIG. 5, can be obtained.

[0058] For example, if contour points Ci−1, Ci and Ci+1 are positioned as shown in FIG. 6, di−1 =13 since Ci is positioned under Ci−1, and di=11 since Ci+1 is positioned at the lower left of Ci. Therefore, the direction code with 16 directions Di=((di−1)+di)/2=12. This direction code indicates an intermediate direction between the direction of a direction code 13 and that of a direction code 11. Generally speaking, if a direction code Di is an odd number, it indicates one of eight directions, as shown in FIG. 4, and if it is an even number, it indicates an intermediate direction between two adjacent directions.

[0059] Then, a 16-value vector is allocated to the points (pixels) of an image. Here, a 0 vector with all of the 16 elements set to 0 is allocated to points other than contour points. As for the contour point Ci, a vector with the Di-th element set to 1 and other elements set to 0 is allocated. The vector field consisting of these 16-value vectors is called a direction code vector field.

[0060] For example, the direction code vector at a contour point Ci shown in FIG. 6 is as follows. (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0)

[0061] In step S3, the feature extracting unit 11 first divides the vertical length y of an image by a predetermined integer M, and designates the quotient L as the size of a basic mesh. Then, the unit 11 designates the quotient obtained by dividing the horizontal length X of the image by L, as n , and divides the entire image by M×n pieces of mesh. According to such a mesh-division, the number of meshes varies depending on the horizontal length, and meshes with a constant size can be obtained.

[0062] Then, in each of the obtained meshes a histogram with a direction code Di is drawn up, provided however, that all the weight coefficients of the histogram are 1. This histogram is generated by adding the direction code vectors of points contained in the mesh, and is indicated by a 16-value vector. Then, it is assumed that this is called a direction code histogram vector, and a vector field consisting of direction code histogram vectors of all meshes is called a direction code histogram vector field. For example, from the following four direction code vectors,

[0063] (1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0)

[0064] (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0)

[0065] (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0)

[0066] (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0)

[0067] the following direction code histogram vector is obtained.

[0068] (1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0)

[0069] In step S4, the feature extracting unit 11 performs only a vertical gradating conversion using a one-dimensional Gaussian distribution function. Here, for example, a one-dimensional Gaussian distribution type filter consisting of five weights, as shown in FIG. 7, is generated and is applied to the direction code histogram vectors of five meshes arranged vertically.

[0070] Thus, the elements of five direction code histogram vectors are weighted and added according to a Gaussian distribution to generate a new direction code histogram vector. Then, the direction code histogram vector of a mesh positioned in the center is updated by the generated direction code histogram vector.

[0071] In this way, by performing only a vertical gradating conversion using a one-dimensional Gaussian distribution type filter, the vertical shift and deformation of characters can be absorbed. As to the horizontal direction which is the connecting direction of characters, direction code histogram vectors are not weighted and added, and the feature amounts are not mixed on the boundary between two characters. Therefore, the commutative composition operation f described above can be easily defined as described later.

[0072] Here, if an integer m, such that m<M, is determined in advance and m pieces of mesh are selected as the center positions of the filter out of M pieces of vertical mesh, an M×n direction code histogram vector field can be space-information-compressed into an m×n direction code histogram vector field.

[0073] For example, when M=13 and n=13, the image is divided into 13×13 meshes as shown in FIG. 8. Here, if m=7 and meshes marked by 0 are selected as the center positions of the filter, the 13×13 direction index histogram vector field is spaceinformation-compressed into a 7×13 direction code histogram vector field.

[0074] In step S5, the feature extracting unit 11 direction-compresses the vector of a direction code histogram vector field. First, the unit 11 multiplies the values of two elements immediately preceding and following each of the elements corresponding to direction codes 1, 3, 5, 7, 9, 11, 13 and 15 out of the 16 elements of the direction code histogram vector by 0.5, and adds two multiplication results to the value of the element between them. Then, the unit 11 compresses the 16-value vector into an eight-value vector by deleting elements corresponding to direction codes 2, 4, 6, 8, 10, 12, 14 and 16. The remaining eight elements correspond to the eight directions shown in FIG. 4.

[0075] Then, the unit 11 handles all two-element sets of opposite directions out of the eight vector elements as one element, and adds the values of elements corresponding to the direction codes 9, 11, 13 and 15 to the values of elements corresponding to direction codes 1, 3, 5 and 7, respectively. Thus, an eight-value vector is compressed into a four-value vector. Accordingly, a direction code histogram vector field consisting of m×n pieces of four-value vector can be obtained.

[0076] Here, if n pieces of a four-value vector horizontally arranged are taken as a direction code histogram series, m pieces of a direction code histogram series are to be obtained. The feature extracting unit 11 outputs these m pieces of a direction code histogram series as the feature amount of the image.

[0077] For example, if a direction code histogram vector is generated based on the space information compression as shown in FIG. 8, 7 pieces of a direction code histogram series, as shown in FIG. 9, can be obtained. In FIG. 9, aij (i=1, 2, . . . , 7, j=1, 2, . . . , 13) indicates a four-value vector, and νi (i=1, 2, . . . , 7) indicates a direction code histogram series.

[0078] Next, the word dictionary generating process of the feature generating unit 13 is described. It is assumed here that I pieces of word lists δ1, δ2, . . . . , δI are prepared as the word list 14 and the i-th word list δi contains only the IDs of words and the IDs of characters composing the words. However, the IDs of characters are also registered in the individual character dictionary 15 and are referenced when the feature amount of the word is generated.

[0079] When the word list δi to be processed is designated by the feature collating unit 12, the feature generating unit 13 refers to the individual character dictionary 15 for each word contained in it, based on the IDs of its component characters, and generates the feature amount of the word.

[0080] It is assumed here that a word w is composed of characters cl, c2, ..., cK and the feature amount of the i-th character ci is Λi. The feature amount of each character is generated in advance by the same process as described above for the extraction of the feature amount, and is stored in the individual character dictionary 15 together with its ID. At this time, the feature amount Λw of the word w is defined using Λw =ΣΛi where ΣΛi indicates the sum of κ feature amounts Λ, Λ2, . . . , Λκ, and the sum Λ1+Λ2 of two feature amounts Λ1 and Λ2 is defined by the following composition operation.

[0081] It is assumed here that Λ1=(λ11, λ12, . . . , λ1 m) and Λ2=(λ21, λ22, . . . , λ2 m) using m pieces of direction code histogram series λ1i and λ2i (i=1, 2, . . . , m). At this time, λ1+λ2=(λ11λ21, λ12λ22, . . . , λ1 m λ2 m) using m pieces of direction histogram series λ1iλ2i.

[0082] Here, λ1iλ2i indicates a new direction code histogram series generated by arranging the direction code histogram series λ2i after the direction code histogram series λ1i as it is. If each of λ1i and λ2i consists of n pieces of a four-value vector, λ1iλ2i consists of 2n pieces of a four-value vector.

[0083] For example, if m=7 and n=13, the feature amounts λ1, λ2 and λ1+λ2 are as shown in FIG. 10. In FIG. 10, the direction code histogram series λ1i (i=1, 2, . . . , 7) of λ1 consists of 13 pieces of four-value vector aij (j=1, 2, . . . , 13), and the direction code histogram series λ2i (i=1, 2, . . . 7) of λ2 consists of 13 pieces of four-value vector bij (j=1, 2, . . . , 13).

[0084] λ1+λ2 is generated by horizontally arranging λ1 and λ2 as they are, and its direction code histogram series λ1iλ2i (i=1, 2, . . . , 7) consists of 26 pieces of four-value vector cij (j=1, 2, . . . , 26). cil to ci13 match ail to ai13, and ci14 to ci26 match bi1 to bi13. In other words, in the case of j=1, 2, . . . , 13, cij=aij, and in the case of j=14, 15 , . . . , 26, cij=bi(j-13).

[0085] Next, the process of the feature collating unit 12 is described with reference to FIGS. 11 to 13. FIG. 11 is a flowchart showing the processes of both the feature collating unit 12 and the feature generating unit 13. It is assumed here that the word list 14 referred to contains S pieces of words, from the 0th to the (S-1)-th.

[0086] First, the feature collating unit 12 sets a control variable i to its initial value of 0 (step S11), and compares i with the total number S of words contained in the word list 14 (step S12). If i is smaller than S, the unit 12 requests the feature generating unit 13 to generate the feature amount of the i-th word.

[0087] Upon receiving this request, the feature generating unit 13 accesses the word list 14 (step S13), and generates the feature amount of the i-th word from the feature amounts of the individual character dictionary by performing the above-mentioned process (step S14). Then, the unit 13 outputs the generated feature amount of the word to the feature collating unit 12.

[0088] Then, the feature collating unit 12 collates the feature amount of the image inputted from the feature extracting unit 11 with the feature amount of the i-th word inputted from the feature collating unit 12 in a memory, and calculates a distance (degree of similarity) between the two feature amounts (step S15).

[0089] Then, the feature collating unit 12 releases the memory area storing the feature amount of the i-th word (step S16), increments i by one (step S17), and repeats the processes in and after step S12. Since the memory area is cleared in step S16, the feature amount of the (i+1)-th word can be written there, and thereby memory space can be saved. When in step S12, i reaches S, the unit 12 terminates the process.

[0090] In step S15, in order to absorb the horizontal shift and deformation of characters, the feature collating unit 12 performs the following distance calculation. First, it is assumed that the feature amount of an input image is N=(ν1, ν2, . . . , νm) and the feature amount of a word to be compared is Λ=(λ1, λ2, . . . , λm), provided however, that νi and λi (i=1,2, . . . , m) are the direction code histogram series as shown in FIG. 9. At this time, the distance D (N, Λ) between two feature amounts N and Λ is expressed as follows.

D (N, Λ)=ΣD (νi, λi)   (1)

[0091] where ΣD (νi, λi) is the sum of the distance D (νi, λi) between two direction code histogram series νi and λi, with respect to it.

[0092] A direction code histogram series is a four-value vector series as described above. If the direction code histogram is discomposed into vector elements, it can be considered to be four numerical series. If the j-th numerical series of the direction code histogram series νi is assumed to be νi(j) (j=1, 2, 3 and 4), they are expressed as follow.

νi=(νi(1), νi(2), νi(3), νi(4)),

λi=(λi(1), λi(2), λi(3), λi(4))   (2)

[0093] At this time, D (νi, λi) is expressed as follows.

D (νi, λi)=ΣD (νi(j), λi (j))  (3)

[0094] where ΣD (νi(j), λ(j)) is the sum of the distance D (νi(j),Λi(j)) between two numerical series νi(j) and λi(j), with respect to j. The distance D (νi(j), λi(j)) can be calculated using a DP.

[0095] DP matching is well known as a matching method for time series data, such as voice data, etc. When two sets of data are collated, the local features of data are focussed, and an evaluation function indicating the quality of the entire matching is defined. Here, the distance between two sets of data is calculated from the value of this evaluation function.

[0096]FIG. 12 shows a DP matching method between a numerical series {x1, x2, . . . , xn} consisting of n numeric values and a numerical series {y1, y2,. . . yp) consisting of p numeric values.

[0097] Here, the numerical series {x1, x2, . . . , xn} and {y1, y2, . . . , yp) are arranged on the x and y axes of a xy-coordinate plane, respectively, and the matching between the two numerical series are indicated by a plurality of dotted points on the plane. While an evaluation function g (xi, yj) is calculated in order, with a point (x1, y1) as a start point, according to a predetermined recurrence formula in a calculation area A, two points in the two different numerical series are matched. Then, the distance between the two numerical series can be obtained from g (xn, yn).

[0098]FIG. 13 shows a calculation in which g (xi, yj) is obtained from g (xi-1, yj), g (xi-1, yj-1) and g (xi-1, yj-1) already obtained in the DP matching process. Here, for example, the following recurrence formula is used.

g (xi, yj)=min {g (xi−1, yj)+d (xi−1, yj),

g (xi−1, yj−1)+2*d (xi−1, yj−1),

g (xi, yj−1)+d (xi, yj−1)}  (4)

[0099] where g(xi, yj) indicates the value of an evaluation function at the time of matching a partial numerical series {x1, x2, . . . , xi} with a partial numerical series {y1, y2, . . . , yj). d (xi, yj) indicates a distance at the time of matching a numeric value xi with a numeric value yj, which can be obtained by the following formula.

d (xi, yj)=|xi−yj|  (5)

[0100] min{} indicates the minimum value of the three elements within {}. In this way, and with use of formula (4), only a matching between the partial numerical series {x1, x2, . . . , xi} and {y1, y2, . . . yj} such that g (xi, yj) is minimized, is adopted and g (xi, yj) is stored.

[0101] By repeating such a calculation, the numerical series {x1, x2, . . . , xn} and (y1, y2, . . . , yp} are matched, and g (xn, yp) can be obtained. Then, g (xn, yp)/(n+p) is designated as a distance between the two numerical series. The shorter the distance, the more similar the two numerical series; and the longer the distance, the more different the two numerical series.

[0102] In this way, if a distance D (νi(j), λi(j)) is calculated using a DP matching method, a distance D (N, Λ) between two feature amounts can be obtained using formulas (1) and (3).

[0103] In DP matching, the combination of two numerical values has flexibility, and two numerical series can be non-linearly matched. Using this flexibility, the horizontal shift of the features of an image can be somewhat absorbed. In this way, the feature amount in this embodiment can be used without a gradation process in the connecting direction of characters by replacing a conventional gradation process with DP matching in the distance calculation of feature amounts. For the distance calculation of the feature amounts, an arbitrary non-linear matching method for which the shift of features can be absorbed, can also be used in addition to DP matching.

[0104] Next, its process flow is described using a concrete example of an input image. Here, a case where the recognizing process of a part of

in a character string image shown in FIG. 14 is completed and a part of

is inputted in succession, is studied. At this time, the feature amount is extracted from the input image of

and a feature collating process is executed according to the procedural flow shown in FIG. 15.

[0105] It is assumed that the words of

and

are registered in the word list 14 and the feature amount of all their characters are registered in the individual character dictionary 15.

[0106] First, the feature amount of

and

are extracted from the individual character dictionary 15 according to the word list 14, and then the feature amount of

is composed (step S21). Then, the composed feature amount of

and the feature amount of the input image are collated, and a distance between the two feature amounts is stored (step S22). Then, the memory area for the feature amount of

is released (step S23).

[0107] Then, since

is a one-character word, the feature amount of

is extracted from the individual character dictionary 15 and is stored in the released memory area (step S24). Then, the feature amount of

and the feature amount of the input image are collated, a distance between the two feature amounts is stored, and the memory area for the feature amount of

is released (step S26).

[0108] Then, the feature amount of

and

are extracted from the individual character dictionary 15, and the feature amount of

is composed in the released memory area (step S27). Then,the composed feature amount of

and the feature amount of the input image are collated, a distance between the two feature amounts is stored (step S28), and the memory area of the feature amount of

is released (step S29).

[0109] Such a collation process is executed for all the words contained in the word list 14. When this collation process is completed, those words are outputted as the recognition result in ascending order of distance.

[0110] Although in FIGS. 14 and 15, the processing of words consisting of kanji is described, words including hiragana, katakana, alphanumerics, symbols, etc., are also processed in the same way. In addition to Japanese, the same process can be applied to the word recognition of an arbitrary language, such as Chinese, Korean, English, German, French, etc.

[0111] Furthermore, in addition to word recognition, the present invention can be applied to the recognizing process of pattern strings consisting of one or more individual patterns. In this case, lists with registered pattern string recognition candidates, are prepared instead of word lists, and a dictionary in which the feature amounts of individual patterns are registered is prepared instead of the individual character dictionary. Then, in the course of the recognition process of an image the feature amount of a pattern string is dynamically generated from the individual pattern dictionary, and the pattern string is collectively recognized.

[0112] The word recognizing apparatus shown in FIG. 2 can be configured using an information processing device (computer) shown in FIG. 16. The information processing device shown in FIG. 16 includes a CPU (central processing unit) 21, a memory 22, an input device 23, an output device 24, an external storage device 25, a medium driving device 26, a network connecting device 27 and an optical-electrical converting device 28, which are connected with each other using a bus 29.

[0113] The memory 22 includes, for example, a ROM (read only memory), a RAM (random access memory), etc., and stores programs and data to be used in the process. The CPU 21 executes necessary processes by running a program using the memory 22.

[0114] The feature extracting unit 11, feature collating unit 12 and feature generating unit 13 shown in FIG. 2 correspond to software components stored in the specific program code segments of the memory 22. Both the word list 14 and the individual character dictionary 15 are stored in a specific area of memory 22 as data.

[0115] The input device 23 corresponds to, for example, a keyboard, a pointing device, a touch panel, etc., and is used for the input of instructions and information from a user. The output device 24 includes, for example, a display, a printer, a speaker, etc., and is used for the output of inquiries and information to a user.

[0116] The external storage device 25 corresponds to, for example, a magnetic disk device, an optical disk device, a magneto-optical disk device, etc., and stores information. It is also possible for the abovementioned programs and data to be stored in this external storage device and used by downloading them to the memory 22, if required.

[0117] The medium driving device 26 drives a portable storage medium 30, and accesses its recorded contents. For the portable storage medium 30, an arbitrary computer-readable storage medium, such as a memory card, a floppy disk, a CD-ROM (compact disk read only memory), an optical disk, a magneto-optical disk, etc., is used. It is also possible that the abovementioned programs and data are stored in this portable storage medium 30 and are used by downloading them to the memory 22, if required.

[0118] The network connecting device 27 communicates with an external apparatus through an arbitrary network (line), such as a LAN (local area network), etc., and converts data during communication. If required, it is possible for the device 27 to receive the above-mentioned programs and data from the external apparatus and to use them by downloading them to the memory 22.

[0119] The optical-electrical converting device 28 corresponds to, for example, an image scanner, etc., and converts an image into digital data and inputs the data. The inputted image data are read into the memory 22, and the feature amount is extracted from the data.

[0120]FIG. 17 shows computer-readable recording media which can provide the information processing device shown in FIG. 26 with programs and data. The programs and data stored in the portable storage medium 30 or an external database 31 can be stored in the memory 22. Then, the CPU 21 runs the programs using the data, and executes necessary processes.

[0121] According to the present invention, a word can be collectively recognized, without restricting the scope of words, by dynamically generating a word dictionary from an individual character dictionary. Accordingly, word recognition is available for arbitrary use.

[0122] Since the present invention adopts a non-linear matching method, such as DP matching, for the distance calculation of the feature amount and the method used to generate a mesh in the connecting direction of characters is made variable, and a certain degree of recognition accuracy is also maintained in word recognition. 

What is claimed is:
 1. A word recognizing apparatus, comprising: listing means for storing a list of at least one word; dictionary means for storing feature amounts of a plurality of characters; generating means for generating a feature amount of a word stored in said listing means using the feature amounts of characters stored in said dictionary means; and collating means for collating the generated feature amount of the word with a feature amount of a recognition target and outputting a recognition result.
 2. The word recognizing apparatus according to claim 1, wherein said collating means includes a memory means which stores the feature amount of the word, and releases the memory means when a collation of the feature amount of the word is completed, and stores a feature amount of the next word.
 3. The word recognizing apparatus according to claim 1, further comprising: inputting means for inputting an image as the recognition target; and extracting means for performing a one-dimensional gradating conversion in a direction perpendicular to a connecting direction of characters for a direction code histogram of a contour line in each of a plurality of small areas in an inputted image and extracting a direction code histogram series obtained from a conversion result as the feature amount of the recognition target.
 4. The word recognizing apparatus according to claim 3, wherein said extracting means divides a length of the inputted image in the direction perpendicular to the connecting direction of characters by a predetermined integer and divides the image into the small areas with an obtained quotient as a size of each of the small areas.
 5. The word recognizing apparatus according to claim 1, wherein said generating means generates the feature amount of the word by using feature amounts of a plurality of characters.
 6. The word recognizing apparatus according to claim 5, wherein said generating means generates a new direction code histogram series by arranging a plurality of direction code histogram series corresponding to the feature amounts of characters composing the word and designating a generated direction code histogram series as the feature amount of the word.
 7. The word recognizing apparatus according to claim 1, wherein said collating means performs a non-linear matching of the feature amount of the word and the feature amount of the recognition target, and calculates a degree of similarity between the feature amount of the word and the feature amount of the recognition target.
 8. The word recognizing apparatus according to claim 1, wherein said listing means stores a list which has a high possibility of containing a word corresponding to the recognition target.
 9. A word recognizing apparatus, comprising: generating means for dynamically generating a feature amount of a word using feature amounts of characters; and collating means for collating the generated feature amount of the word with a feature amount of a recognition target, and for outputting a recognition result.
 10. A recognizing apparatus, comprising: generating means for dynamically generating a feature amount of a pattern string using feature amounts of patterns; and collating means for collating the generated feature amount of the pattern string with a feature amount of a recognition target, and for outputting a recognition result.
 11. A computer-readable storage medium on which is recorded a program causing a computer to execute a process, said process comprising the steps of: dynamically generating a feature amount of a word using feature amounts of characters; and collating the generated feature amount of the word with a feature amount of a recognition target.
 12. A computer-readable storage medium on which is recorded a program causing a computer to execute a process, said process comprising the steps of: dynamically generating a feature amount of a pattern string using feature amounts of patterns; and collating the generated feature amount of the pattern string with a feature amount of a recognition target.
 13. A recognizing method, comprising the steps of: generating a list of at least one pattern string; generating a dictionary for storing feature amounts of a plurality of patterns; dynamically generating a feature amount of a pattern string stored in said list using feature amounts of patterns stored in said dictionary; and collating the generated feature amount of the pattern string with a feature amount of a recognition target. 